草庐IT

c++ - std::equal_range 与 lambda

全部标签

c++ - Clang UBSAN 报告类型 'std::_Ios_Fmtflags' 的无效值

以下代码用clangUBSAN编译会崩溃#include#include#include#includetemplateinlinestd::stringfloatToString(Ti){printf("infloatToString\n");std::stringstreamss;ss.precision(6);ss用Clang3.6编译:$>clang++-3.6-fsanitize=undefined-fno-sanitize=float-divide-by-zero,vptr,function-fno-sanitize-recover-otesttest.cpp然后程序崩溃了

c++ - 当 Cortex-M3 出现硬故障时如何保留堆栈跟踪?

使用以下设置:基于Cortex-M3的µCgcc-armcrosstoolchain使用C和C++FreeRtos7.5.3eclipse月神将Jlink与JLinkGDBServer分离CodeConfidenceFreeRtosdebugplugin使用JLinkGDBServer和eclipse作为调试前端,在单步执行我的代码时,我总是有一个很好的堆栈跟踪。使用CodeConfidencefreertos工具(eclipse插件)时,我还看到了当前未运行的所有线程的堆栈跟踪(没有该插件,我只看到事件线程的堆栈跟踪)。到目前为止一切顺利。但是现在,当我的应用程序陷入硬故障时,堆栈跟

c++ - 指向结构的 std::vector 的指针

structStruct_t{intValue1;intValue2;};vectorStruct;Struct.resize(10,Struct_t());for(inti=0;i如何创建指向Struct[i]的指针?我想做的基本上是这样的,但我相信这可以做得更好:intvalue=6;Struct_ttemp=Struct[value],*s;s=&temp;s->Value1=42;s->Value2=6;主要目标是,我可以使用1行/函数轻松创建指向Struct[n]的指针。 最佳答案 到目前为止,提供的答案缺少房间里的大象。

c++ - 在单个函数中混合 '__try' 和 'try' - 通过 Lambda

众所周知,WindowsSEH不支持C++异常处理机制。我们不能在单个函数中使用try和__try。这将导致编译器错误:__try{try{MayThrowCPPException_OR_SEH();}catch(...){}}__except(EXCEPTION_EXECUTE_HANDLER){}它将呈现:C2713:Onlyoneformofexceptionhandlingpermittedperfunction.大多数人不喜欢的一个选项是“YeswithSEHExceptions(/EHa)”编译器选项。这将有助于C++try/catch处理这两个异常。我们需要将这样的函数放

c++ - fatal error : 'common.h' file not found under mac osx 10. 10.5

我按照操作系统:三个简单的部分这本书,introductionchapter中的代码,#include#include#include#include#include"common.h"intmain(intargc,char*argv[]){if(argc!=2){fprintf(stderr,"usage:cpu\n");exit(1);}char*str=argv[1];while(1){Spin(1);printf("%s\n",str);}return0;}当我尝试gcc-ocpucpu.c-Wall时,错误出来了:fatalerror:'common.h'filenotfo

c++ - header 中的枚举导致过度重新编译

JohnLakosreferstothisproblemasaninsidioussourceofcompile-timecoupling(Figure0-3,inhisIntroduction):我面临的问题是编译了太多文件,因为对单个枚举存在物理依赖性。我有一个带有枚举定义的header://version.henumVersion{v1=1,v2,v3,v4,v5,...v100};这被数百个文件使用。每个文件定义一类对象,必须从磁盘读取,使用read()功能。Version用于确定数据的读取方式。每次引入新的类或类成员时,都会将新条目附加到枚举中//typeA.cpp#incl

C++ std::ofstream - 移动放置指针

我正在将一些数据写入文件。有时,我想从内存中写入一个数据block,然后将put指针移动1、2或3个字节以保持4字节的数据边界格式。我可以制作一个包含零的新数据block并写入它,但这似乎没有必要且笨拙。如何将put指针移动1、2或3个字节?我不确定该怎么做,因为如果我调用seekp()肯定会将指针移到当前文件大小之外?而我假设ofstream.write()正确地处理了这个问题?即:它在写入数据时以某种方式调整文件大小? 最佳答案 我假设你正在做类似的事情,除了你不想写两个字节的数据,而是想写4个字节并加上一些填充。#includ

c++ - 缩短字符串时 std::string::resize 和 std::string::erase 之间的区别

当缩短std::string时,基本上有两种可能性:string.resize(length)或string.erase(length).既然我们知道字符串会变小,那两者有什么区别呢? 最佳答案 resize必须检查length>current或length-它的行为取决于比较的结果。erase总是减少字符串的长度在异常安全方面存在差异:resize:强保证:如果抛出异常,则字符串没有变化。(来自here)erase:C++98-等于resize;C++14-函数没有抛出版本(来自here)

c++ - 在使用 gdb 检查核心转储时,有没有办法运行函数(如 std::string.size())?

考虑一个产生某些段错误并中止的C++程序。在使用gdb进行常规调试时,我可以执行以下操作并查看结果(gdb)r(gdb)pstr_var.size()其中str_var在文件中定义为std::string。但是,我在使用核心转储进行调试时遇到了一些问题。在我通过在gdb中加载核心转储之后gdbEXECUTABLEcore.pid然后在gdb终端运行以下命令(gdb)pstr_var.size()gdb说“如果没有调试过程,你就不能这样做。”我只能做bt(查看堆栈跟踪)或直接打印std::string变量之类的事情,但是找不到一种简单的方法来检查一些信息,例如打印std::string的

c++ - 在#include 中获取当前编译单元名称

我当前的目标是创建一行(或尽可能少的)代码,将事件编译单元的其余部分切换到未优化的调试配置。我的第一直觉是:FORCE_DEBUG;//codebelowherewillbeforcedtobeunoptimizedandinadebugenvironment或#include"ForceDebug.h"//codebelowherewillbeforcedtobeunoptimizedandinadebugenvironment会很理想。在我的工作区中,要转换为未优化的调试配置,我需要更改pragma优化级别,还需要#undef一些宏和#define其他宏。FORCE_DEBUG宏不